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(57) Abstract: A recovery time upon the failure of a link 
or switching system (202, 204, 206, 208) in an asynchronous 
data network (200) can be minimized if downstream data 
switches (204, 206, 208) provide upstream messages (220, 
222) indicating to upstream switching system (202) that the 
downstream traffic (218) arrived in tact and was properly 
handled. Upon this loss or failure of the upstream status 
message (220, 222) to an upstream switching system (202), 
an upstream switching system (202) can reroute data traffic 
around a failed link or failed switch with a minimal amount 
of lost data. The upstream status message (220, 222) is 
conveyed from a downstream switching system (204, 206, 
208) to an upstream switching system (202) via a reverse 
notification tree data pathway (214). The reverse notification 
pathway (214) is established by using a messaging protocol 
between network switches (202-208) by which the working 
and protection path, among other things, are established. 
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METHOD FOR ESTABLISHING AN MPLS DATA N ETWORK 
PROTECTION PATHWAY 

RELATED APPLICATIONS 

This application claims priority under 35 U.S.C. §1 1.9(e) to provisional applications 
serial nos. 60/160,840 , filed October 21, 1999, 60/161,277 filed October 25, 1999 and 
60/187,798 filed March 8, 2000, the entire writing and content of which is incorporated by 
reference. 

FIELD OF THE INVENTION 

This invention relates to data networks. In particular this invention relates to a method 
and apparatus for automatically routing a message upstream through a multi-protocol label 
switching (MPLS) network so as to trigger the re-routing of data onto an alternate path 
through the MPLS network. 
BACKGROUND OF THE INVENTION 

Multiprotocol Label Switching (MPLS) is a new technology that combines OSI layer 
2 switching technologies and OSI layer 3 routing technologies. The advantages of MPLS 
over other technologies include the flexible networking fabric that provides increased 
performance and scalability. This includes Internet traffic engineering aspects that include 
Quality of Service (QoS)/Class of Service (COS) and facilitate the use of Virtual Private 
Networks (VPNs). 

The Internet Engineering Task Force (IETF) defines MPLS as a standards-based 
approach to applying label switching technology to large-scale networks. The IETF is 
defining MPLS in response to numerous interrelated problems that need immediate attention. 
These problems include, scaling IP networks to meet the growing demands of Internet traffic, 
enabling differentiated levels of IP-based services to be provisioned, merging disparate traffic 
types onto a single IP network, and improving operational efficiency in a competitive 
environment. 

The key concept in MPLS is identifying and marking IP packets with labels and 
forwarding them to a modified switch or router, which then uses the labels to switch the 
packets through the network. The labels are created and assigned to IP packets based upon 
the information gathered from existing IP routing protocols. 

The label stack is represented as a sequence of "label stack entries". Each label stack 
entry is represented by 4 octets. 
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0 1 2 3 

012 3 45678901234567890123 4 5 678901 

+ .+.+.+.+.+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- + - + - + - + - + - + - + - + - + ' + " + Label 
| Label | Exp |S| TTL | Stack 

Label: Label Value, 20 bits 
Exp: Experimental Use, 3 bits 
S: Bottom of Stack, 1 bit 
TTL: Time to Live, 8 bits 

The label stack entries appear after the data link layer headers, but before any network 
layer headers. The top of the label stack appears earliest in the packet, and the bottom appears 
latest. The network layer packet immediately follows the label stack entry which has the S bit 
set. 



Multi-protocol label switching (MPLS) networks are typically comprised of several 
packet-based switching systems interconnected by a variety of media (e.g., coaxial or fiber 
optic cable, unshielded twisted pair or even point-to-point microwave wireless) in a mesh- 
topology network similar to the public switched telephone network. In such a network, there 
might be several paths through the network between any two endpoints. MPLS networks 
carry data as packets wherein each packet includes a label on identifying a switched path 
through the network. The data label is appended to data packets so as to define a pathway 
through the network over which the data packets are to be routed. 

A problem with any data network, including an MPLS network, is the amount of time 
required to recover from either a link failure or a switch failure. Empirical data shows that the 
time required to recover from a network failure can take several seconds to several minutes, 
an unacceptably long time. A method and apparatus by which the recovery time for a link or 
switch failure can be reduced to perhaps less than a few hundred milliseconds would be a 
significant improvement over the prior art fault recovery mechanisms used on MPLS 
networks to date. A method and apparatus by which a switch over from a working path to a 
protection path would facilitate MPLS network reliability. 
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SUMMARY OF THE INVENTION 

In an MPLS data network comprised of various transmission media linking various 
types of switching systems, network fault recovery time is reduced by using a reverse- 
directed status message that is generated by a data switch that is down-stream from a 
5 switching system from which data is received. The reverse-directed or upstream status 

message is sent over a pre-determined pathway (i.e. through pre-determined switches and/or 
over pre-determined data links) which originates from a destination switch or node in an 
MPLS network to upstream switching systems. This so-called reverse notification tree carries 
a message or messages that are used to indicate the functionality (or non-functionality) of the 

1 0 downstream switch, switches or links of the MPLS network. As long as an upstream MPLS 
switching system continues to receive the reverse-directed status message from a downstream 
switch via the reverse notification tree, the switching systems that receive such a message 
consider the downstream switch and pathways to be in intact. Accordingly, data packets 
continue to be sent downstream for subsequent routing and/or processing. If the reverse- 

1 5 directed status message is lost or discontinued, either because of a switch failure or a link 

failure, the upstream switching system considers the downstream switch or link to have failed 
and thereafter begins executing a procedure by which data is rerouted over an alternate data 
path through the network. In the preferred embodiment, the alternate data path over which 
downstream information ins sent is a pre-established protection path and is known to a 

20 protection switch in advance, thereby minimizing data loss attributable to the time it might 
take to calculate a dynamic alternate protection path. 

Switches in the network and their interconnections can be modeled using a directed 
acyclical graph by which a downstream switch knows the identity of the upstream switch to 
which the failure notice should be sent. In the preferred embodiment, at least one upstream 

25 switch routing the MPLS data re-directs data onto a protection path through the network 

between the same two endpoints by using the reverse notification tree. By way of the reverse 
notification tree, data loss caused by either a link or switch failure can be minimized by the 
prompt rerouting of the data through an alternate or recovery data path through the network. 
BRIEF DESCRIPTION OF THE DRAWINGS 

30 Figure 1 shows a simplified block diagram of an MPLS protection configuration. 

Figure 2 depicts exemplary message flows in an MPLS network. 
DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT 

Figure 1 shows a simplified block diagram of a packetized-data switching network 
100. Each of the squares shown in Figure 1 including boxes represented by reference 
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numerals 102, 104, 106, 108, 1 10 J 12, 1 14, 1 16, 1 18 and 120 represent one or more types of 
asynchronous switching systems that asynchronously receive data in e.g., packets, cells or 
frames from an "upstream" switch and route, direct, couple or otherwise send the data 
onward to another "downstream" switch logically closer to the ultimate destination for the 
5 data. By way of example, these switching systems might be internet protocol (IP) routers, 
asynchronous transfer mode (ATM) switches, frame relays switches or other types of 
packetized-data switching systems implemented to receive packetized data over a 
transmission line and reroute the data onto one or more output ports to which are connected 
transmission media coupled to other switching systems. 

10 In Figure 1 , switching system number 1 , (identified by reference numeral 1 02) is 

coupled to another switching system, no. 2, (represented by reference numeral 104) and 
switching system no. 5 (represented by reference numeral 120) via links L12 and P25 
respectively. Switching system no. 2 and no. 5 are "downstream" from no. 1; no. 1 is 
considered to be "upstream" from switch no. 2 and no. 5. 

1 5 Similarly switching system no. 3, (represented by reference numeral 1 06) is coupled 

to switching systems 2, 4 and 9 (represented by reference numerals 104, 108 and 116 
respectively) via transmission links L 2 3, L 34 , and L93 respectively. 

In routing data between switch no. 1 (represented by reference numeral 102) and 
switch no. 7 (represented by reference numeral 112) data might be routed between these two 

20 endpoints through a "primary " path that is comprised of links that logically or physically 

couple switches 2, 3, 4, 6 and 7 (identified by reference numerals 104, 106, 108, 1 10 and 1 12 
respectively). The physical or logical links of the primary path between the endpoints which 
is 1 and 7 are represented by the vectors designated Ln, L 2 3, 1-34, L46 and L67- This path is 
known in the art as the working of primary path through the network. The links of the various 

25 paths shown in Figure 1 (represented by the vectors L12, L23, L34, L46 and L67) , and therefore 
the paths themselves, might be constructed of direct pathways (e.g., fiber optic cable, coaxial 
cable, unshielded twisted pairs of copper wires, or microwave radio) between the various 
switches. Alternate embodiments of the paths or links between switches of the network of 
Figure 1 would also include using direct pathways, and intermediate switches or switch 

30 networks, (not shown in Figure 1 , but still part of the path or link coupling one or more 
switching systems to another). By way of example and not of limitation, the data switches 
shown in Figure 1 might be IP switches but such IP switches could be linked together using 
one or more ATM switches or ATM networks. 
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The MPLS Protection Path 

In an MPLS network, there is almost always a "protection " path, which is an 
alternate path through the network linking two endpoints. The protection path entry and exit 
points are usually accessible to only protection switches. A protection switch is a switch that 
5 can re-route traffic onto a protection pathway. Like the other links described above, a 
protection pathway can be comprised of direct data paths, but also switches or switching 
systems, by which data can be sent through a network between two or more endpoints. 

In an MPLS network, a protection path is set up using at least one protection switch 
element so as to be able to carry data from a source to a destination in the event the primary 
10 path or switch thereof fails for one reason or another. The operation of a protection switch is 
shown in Figure 1 by way of example. 

In Figure 1, a working path between switch 1 and 7 exists through switches 1, 2, 3, 4, 
6 and 7 and the links between the switches. A protection path for the portion of the working 
path that runs through switches 2, 3, 4 and 6 is the path designated by links P 25 and P 27 and 
15 which runs through switch 5, (identified by reference numeral 120). The protection path 

extends between endpoint switches 1 and 7 but through only switch 5 (identified by reference 
numeral 120). Alternate embodiments of a protection path might extend through multiple 
switches. In the network 100, either a link or switch loss between switch 1 and 7 can be 
overcome by re-routing traffic for switch 2 through switch 5 instead. Switch 5 then routes the 
20 data to switch 7. Switch 1 (identified by reference numeral 1 02) is considered to be a 
protection switch element. 

Another working path between switch 8 and switch 7 of the network 100 (identified 
by reference numerals 1 14 and 1 12 respectively) exists through switches 9, 3, 4, 6 & 7 
(identified by reference numerals 1 16, 106, 108 and 1 10 respectively) and the links between 
25 them. A protection path for data from switch 8 (reference numeral 1 14) to switch 7 (reference 
numeral 112) through the network 100 exists via switch 10, (reference numeral 118) such that 
if data traffic from switch 8 (reference numeral 1 14) is lost somewhere between switch 9 
(reference numeral 1 16) and switch 7 (reference numeral 112), switch 9 can re-route such 
data traffic to switch 10 (reference numeral 118). Switch 10 can then route such data to 
30 switch 7. Switch 9 is therefore considered to be a protection switch element. 

If an alternate data path, i.e. a protection path, is pre-determined, i.e. set up or 
established in advance, data loss attributable to a switch or link failure can be minimized. If a 
protection switch is pre-programmed to re-route data upon its receipt of an appropriate 



5 



10 



15 



20 



25 



30 



PCT/US00/29O51 

WO 01/29682 

command or signal, the protection switch element can almost .mmed.ately start sending data 
to the proper destination via the protection path. 

The. I .iveness Message 

1„ the event of a pathway failure, sueh as either a switch failure or a link failure, 
anywhere a!ong a primary or working path, a protection switch element (PSL), sueh as sw.teh 
no 1 (identified by reference numeral 102) can re-route data traffic through the protection 
path so as ,o have the data for the endpoint switch no. 7 delivered as quickly as possible to 
me endpoin, a, switch no. 7 (identified by reference numeral 1 1 2). th. ability to re-route data 
to a protection path is made considerably more valuable if the deciston to switch over to a 
protection path is based upon an affirmative notice that a switch over is needed. Th,s 
affirmative notice is in the form of an upstream .iveness message, the loss of which tndtca.es 
a pathway failure. As long as a liveness message is received at an upstream switch from a 
downstream switch, the upstream switch can assume mat the pathway betiveen the mo 
switches is intact and that the downstream switch is functional. 

in the event of a switch or link failure anywhere between the path endpoint swrtches 1 
.d 7 data re-routing >s accomplished faster by using a reverse-directed status message that 
is sent backward or upstream toward the protection switch element no. 1 (reference numeral 
102) by one or more of the switches 2, 3, 4, 6 or 7 (reference numerals 104, 106, 108, 1 10 or 
, 1 2) of the primary pathway, links Ln. L 2J , I*. I* I* In the preferred embodiment thus 
reverse direction data message is known as a "liveness message" the format of wh.cn ,s a 
design choice and dependent upon nature of me switches of the network 1 00, but me function 
of which is to indicate to upstream switches that me data traffic sen. «o me downstieam 

switch arrived intact and on time. 

The structure of a liveness message will vary depending upon whether the network 
switches are ATM, IP, Ethernet or other types of switches, as those skilled in the art will 
recognize Unlike known fault detection methods, the liveness message is not a copy, or 
loop-back of the downstream data. The salient aspect of the liveness message is that * xs an 

indicating the operational condition of the switch from which it was sent. Alternate 
embodiments include sendmg a liveness message aperiodically. The fact that the liveness 
message is received at an upstream switch (with respect to the downstream data) is evxdence 
that the link between the switches, over which downstream data would be sent, is mtact and 
that the switch that generated the liveness message is at least somewhat functional. 
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While the preferred embodiment contemplates that the liveness message is sent 
upstream from a switch, directly to the switch that sent the downstream data, alternate 
embodiments of the invention contemplate that the liveness message could be sent between 
other nodes, or from one switch to an intermediate transfer point, which for purposes of claim 
5 construction are considered to be equivalent embodiments. By way of example, with 

reference to Figure 1, switch no. 4 (identified by reference numeral 108) will send a liveness 
message, upstream to switch no. 3 (reference numeral 106) in response to data sent 
downstream from switch no. 3 to switch no. 4. If the liveness message from switch no. 4 is 
lost by or not received by switch no. 3, switch no. 3 immediately knows that either the link 

1 0 L 34 between the two switches failed, or switch no. 4 failed. If switch no. 3 was carrying data 
from switch no. 9 (reference no. 1 16) and which is a protection switch element having access 
to a protection path, switch no. 3 would need to inhibit its liveness message to switch no. 9 or 
generate an error message to switch no. 9, thereby instructing switch no. 9 to re-route traffic 
from switch no. 3, to the protection path through switch no. 1 0 (reference numeral 118) 

1 5 As for data routed through switch no. 3 that comes from switch no. 2 (reference 

numeral 104), a liveness message loss from switch no. 4 will require switch no. 3 to inhibit 
the liveness message to switch no. 2, or send an error message to switch no. 2. This procedure 
is then repeated to switch no. 1 , instructing switch no. 1 to make a protection switch through 
switch no. 5 (reference no. 120). 

20 Whenever the liveness message is lost, its failure is considered to be indicative of a 

path failure of either a link or a switch. Still other embodiments of the invention contemplate 
sending a downstream liveness message, sent from an upstream switch to a downstream 
switch thereby indicating to a downstream switch that the upstream switch and link are 
functional. 

25 As set forth above, the format of a liveness message will depend upon the type of 

switching systems used in the network. IP switches and ATM switches will need to comply 
with their respective protocols. Alternative embodiments of the invention would certainly 
contemplate other sorts of liveness messages having different formats with the salient feature 
of the message being that the message indicates to an upstream switch that downstream 

30 directed data messages were received by a downstream switch intact. 

In Figure 1, the links over which reverse notification status messages (i.e. the liveness 
messages) are sent, are designated by the reverse directed vectors, one of which is shown in 
Figure 1 (and identified by reference numeral R 76 ). By way of example if link L 67 should fail 
causing a data loss to the endpoint switch no. 7, the corresponding loss of the liveness 
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message ordinarily sent from switch 7 to switch 6 would provide an indication to switch no. 6 
that either the link or the switch 7 failed whereupon switch no. 6 would begin notifying the 
protection switch (switch no. 1) upstream from it by way of a reverse notification message 
R M that would be sent to switch no. 4, (represented by reference numeral 108). Similarly, 
switch no. 4 would thereafter return a reverse notification message R43 to switch no. 3. 
Switch no. 3 returns another reverse notification message R 32 to switch 2 which then returns a 
reverse notification message R 2t to the origination node 1 . 

The ultimate destination of the upstream message, and in this case the reverse 
notification message, is a switching node (i.e. a switch or switching system) that is capable of 
re-routing downstream traffic, data or messages onto a different path, i.e., a protection path, 
usually comprised of at least a different transmission route, possibly including a different 
transmission media as well (coax to fiber; fiber to microwave etc.). Whether the upstream 
message goes through another switch on its way to the switching node (which has the 
capability of re-routing data to the protection path) or is directly sent to the switching node 
from a downstream switch around an intermediate switch (for example, sending a liveness 
message directly from switch 6 to switch 1) would still provide equal functionality in that the 
switching node will eventually receive notification that it needs to re-route traffic, data or 
message onto the protection path. Sending the aliveness message directly to the protection 
switch or routing the aliveness message via intervening switches are considered to be 
equivalent embodiments for purposes of claim construction. 

Inasmuch as switch no. 1 in Figure 1 is designated as a "protection switch element- 
meaning that it is coupled to and capable of routing data onto a protection path P 25 , the 
. protection switch el^ . 
no. 7 via a protection path designated by P 25 and P57 and that runs through switch no. 5 
(identified by reference numeral 120). 

In the preferred embodiment, the switches of the network maintain tables of network 
switches upon which incoming data is received and a table of network switches to which 
outgoing data is routed. By keeping a record of where outgoing data from a switch originates 
from, it is possible for a switch of the network 1 00 to promptly notify an upstream switch of a 
downstream link or switch failure. 

In the process described above, each of the switches of the network sequentially 
notifies at least one switch upstream from it. Alternate (and for purposes of claim 
construction, equivalent) embodiments of the invention could certainly provide upstream 
notification messages directly from any downstream switch to every other upstream switch in 
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a pathway. In such an embodiment, switch no. 6 might send a reverse notification message 
directly to the protection switch element 1 via a direct link thereby notifying the protection 
switch to immediately reroute data to the protection path P 27 and P 57 via switch no. 5. Switch 
no. 6 might also send a reverse notification (liveness) message to the other switching systems 
5 of the network as well. 

The Reverse Notification Tree 

The implementation of the upstream notification message, and its conveyance 
upstream to a protection switch element, is enabled by using an upstream pathway 
denominated herein as a reverse notification tree or "RNT." The RNT is an "upstream" signal 

1 0 pathway that allows messages from a protection path end point to be sent "upstream" to one 
or more protection path (and working path) starting point switches, nodes or starting points. 
In the preferred embodiment, the RNT passes through the same switches and over or through 
the links that comprise the working path (albeit over different transmission media) and for 
claim construction purposes can be considered to be "coincident" with the working path. 

1 5 Alternate embodiments of the invention would include a reverse notification tree that runs 
through one or more switches or nodes that are not part of the working path, or which are 
only partly "coincident." 

With respect to Figure 1 , node 7, identified by reference numeral 1 12, is the RNT 
starting point or head end. Nodes 1 and 9, which are identified by reference numerals 102 and 

20 1 1 6, are the end points of the RNT and to which upstream protection switch messages would 
be sent from any node or switch between nodes 1, 9 and 7. Intervening nodes 3, 4 and 6, 
identified by reference numerals 106, 108 and 1 10 respectively, are constituent elements or 
parts of the RNT. 

The RNT can be established in association with the working path(s) simply by 
25 making each switching system along a working path "remember" its upstream neighbor (or 
the collection of upstream neighbors whose working paths converge at a network switching 
element and exit as one). A table or other data structure stored in memory (such as RAM, 
ROM, EEPROM, or disk) of the switches of the paths can be configured to store data 
identifying switches coupled to a switching system in, or part of a working path as well as a 
30 protection path. 

With respect to the network shown in Figure 1, Table 1 below shows that incoming or 
"Ingress" RNT messages to switch no. 3 from switch 4 are labeled "N43" (not shown in 
Figure 1) and that these messages arrive at switch no. 3 from switch 4 at an inbound or 
"Ingress" interface 134 (not shown in Figure 1). Because switch no. 3 receives downstream 
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messages from two (2) different switches, (i.e. switch 2 and switch 9) both of these two 
upstream switches must be sent an upstream notification therefore requiring two separate 
upstream messages from switch 3. Upstream RNT messages to switch 2 are labeled "N32" 
and appear or are sent from interface 123. Upstream RNT messages to switch 9 are labeled 

"N93" and are sent from interface 193. 
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Table 1. An inverse cross-connect reverse notification tree 
table for Switch 3 of Figure 1. 

The reverse path (upstream) to switch 3 from switch 4 is labeled N43; the switch 3 
interface for this data is designated 134. An upstream message received at 134 and that is 
labeled N43, is sent out from switch 3, via the interfaces 123 and 193 and labeled N32 and 
N39 respectively. 

Table 2 shows the egress and interface labels of the working or downstream path from 
switch 3 and the originating switches for that data. 

The working path (downstream) path from switch 3 is to switch 4 and is labeled 
"L34." The switch 3 interface for this data is designated "134." The data sent downstream - 
from switch 3 originates from switch 2 and switch 9, which are referred to in Table 2 as 

"Next Hop" switches. 

Switch no. 2 originates data to switch no. 3 and that data is received at switch no. 3 on 
interface "12." Data from switch no. 9 is received at switch no. 3 at interface "19." The RNT 
or upstream notification to switch no. 2 leaves switch no. 3 on its RNT interface "123." RNT 
notification to switch no. 9 leaves switch no. 3 from "193." 
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Table 2. An inverse cross-connect table for a hop -by-hop 
5 reverse notification tree. 

A fault on the link between switch 3 and 4 in the downstream direction can be detected at a 
downstream node, switch 4 perhaps, via either a path failure (PF) or path defect (PD) condition 
being detected via Link Failure (LF) or Link Defect (LD) signals being propagated to an 

1 0 upstream switch. The downstream node will then periodically transmit fault indication signal 
(FIS) messages to its upstream neighbor (via the uplink R43), which will propagate these further 
upstream (using its inverse cross-connect table) until they eventually reach the appropriate 
Protection Switch Element, which will perform the protection switch. From Table 1, messages 
. received at switch no. 3 are labeled "N43." Therefore, in Fig. 1 , if link L34 has a fault, switch 3 

1 5 will detect the fault via the lost liveness message from switch no. 4 and start transmitting an FIS 
packet back to switch 2 link L 23 as represented by the message R 32 - From Tables 1 and 2, there 
are two egress messages and interfaces from switch no. 3, which identify the upstream switches 
that are to be "notified" of a failure downstream from switch no. 3. (The traffic in the queues of 
switch 3 will continue to be serviced.) By using similar tables, switch 2 in turn will propagate the 

20 FIS over the RNT back to switch 1 . The actual protection switch will be performed by switch 1 , 
after the receipt of the first FIS. Switch 3 will stop transmitting FIS messages "t" time units after 
the transmission of the first FIS message. 

In the preferred embodiment, only one RNT is required for all the working paths that 
merge (either physically or virtually) to form the multipoint-to-point "forward" or 

25 "downstream" path. Figure 1 shows that at least two (2) working paths (one path of which is 
comprised of switch elements 1, 2 and 3 that are identified by reference numerals 102, 104 
and 106; a second path of which is comprised of switch elements 8, 9 and 3 that are identified 
by reference numerals 1 14, 1 16 and 106) converge at switch element 3 (identified by 
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reference numeral 106). Alternate (and for purposes of claim construction, equivalent) 
embodiments would include using multiple RNTs for a single working path that has multiple 
paths that converge at a single node (switches of each path that converges might form 
different RNTs) as well as using multiple RNTs for a single working path. 

5 The RNT- is rooted at an appropriately chosen label switched router ("LSR"), (which 

hereafter is referred to as an MPLS network switch element) along the common segment of 
the merged working paths and is terminated at the protection switch elements (PSLs). 
Intermediate network switching elements on the converged working paths typically share the 
same RNT reducing signaling overhead associated with recovery. Unlike schemes that treat 

10 each network switch element independently, and require signaling between a protection 
switch element and a destination switch individually for each network switch element, the 
RNT allows for only one (or a small number of) signaling messages on the shared segments 

of the label switch paths (LSPs). 

The RNT can be implemented either at Layer 3 or at Layer 2 of the OSI, 7-layer 
1 5 protocol stack. In either case, delay along the RNT needs to be carefully controlled. This may 
be accomplished by giving the highest priority to the fault and repair notification packets, 
which travel along the RNT. We can therefore have a situation where different protection 

domains share a common RNT. 

A protection "domain" is considered to be the switches and links of both a working 
20 path and protection path. For example, in Fig. 1, the protection domain bounded by network 
switch element 1 and network switch element 7, is denoted by {1-2-3-4-6-7, 1-5-7}. 

When different protection domains have different RNTs, two cases may arise, 
depending on whether or not any potions of the two domains overlap, that is, have nodes or 
links in common. If the protection domains do not overlap, the protection domains are 
25 considered to be independent. By virtue of the RNTs in the two domains being different, 
neither of the working paths nor the RNTs of the two domains can overlap. In other words, 
failures in one domain do not interact with failures in the other domain. For example, the 
protection domain defined by {9-3-4- 6-7, 9-10-7} is completely independent of the domain 
defined by {11-13-5-15, 1 1-13-14-15}. As a result, as long as faults occur in independent 
30 domains, the network shown in Fig. 1 can tolerate multiple faults (for example, simultaneous 
failures on the working path in each domain). If protection domains with disjoint RNTs 
overlap, it implies that the protection path of one intersects the working path of the other. 
Therefore, although failures on the working paths of the two domains do not affect one 
another, failures on the protection path of one may affect the working path of the other and 
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visa versa. For example, the protection domain defined by {1-2-3-4-6-7, 1-5-7} is not 
independent of the domain defined by {11-13-5-15, 11-13-14-15} since LSR5lieson the 
protection path in the former domain and on the working path in the latter domain. When 
protection domains have the same RNT, different failures along the working paths may affect 
both paths differently. As shown in Fig. 1, for example, working paths 1-2-3-4-5-7 and 9-3-4- 
6-7 share the same RNT. As a result, for a failure on some segments of the working path, 
both domains will be affected, resulting in a protection switch in both (for example, the 
segment 3-4-6-7 in Fig. 1). Likewise, for failures on other segments of the working path, only 
one domain may be affected (for example, failure on segment 2-3 affects only the first 
working path 1 -2-3-4-6-7, where as failure on the segment 9-3 affects only the second 
working path 9-3-4-6-7). 

There are a number of ways to establish a protection domain, i.e., a working path and 
a protection path through an MPLS network. Establishing a protection path first requires the 
identification of the working path (embodied as some series of switches and path links 
through the MPLS network from a sending node to a destination node). In most cases, the 
working path and its corresponding recovery path are specified during a network switch path 
or connection setup procedure, either via a path selection algorithm (running at a centralized 
location or at an ingress network switch element) or via an administrative configuration (e.g. 
a manual specification of switches that comprise the protection path). 

The specification of either a protection or working path, does not, strictly speaking, 
require the entire path to be explicitly specified. Rather, it requires only that the head end 
node or switching node and end or destination switch or node (of the respective paths) be 
specified. In the absence of a destination switch/node specification, the path egress points out 
of the MPLS network or domain need to be specified, with the segments between them being 
- "loosely" determined or routed. In other words, a working path would be established 
between the two nodes at the boundaries of a protection domain via (possibly loose) explicit 
(or source) routing using LDP/RSVP [label distribution protocol/reservation protocol] 
signaling (alternatively, via constraint-based routing, or using manual configuration), as set 
forth more fully below. 

Figure 2 depicts message flows between four (4) different switches of an MPLS 
network that employs the path protection techniques disclosed herein. Vertical axes of Figure 
2, identified by reference numerals 202, 204, 206 and 208, represent switching elements 
(shown in Figure 1) of an MPLS network from which and to which various types of messages 
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arc received and sent respectively. Switch 202 is upstream from switches 204, 206 and 208. 
Switch 204 is upstream from switch 206 as switch 206 is upstream from switch 208. 
Protection Path Establishment 

A Protection Domain Path is established by the identification of a protection switch or 
node and an end point switch or node in the MPLS network. The protection switchelement 
("PSL") initiates the working network switch elements and the recovery network switch 
element. It is also responsible for storing information about which network switch elements 
or portions thereof have protection enabled, and for maintaining a binding between outgoing 
labels specifying the working path and the protection/recovery path. The latter enables the 
switchover to the recovery path upon the receipt of a protection switch trigger. 

A "label distribution protocol" is a set of procedures by which one LSR (i.e., a 
network switch element) informs another of the label bindings it has made. "Label binding- 
is a process by which a message to be sent from a source to a destination is associated with 
various labels between the nodes that lie along the way, between the source and destination. 
By way of example, in Figure 1, a message to be sent from switch 1 to switch 7 is associated 
or bound to travel to switch 7 through switch 2 by, or using, the label L 12 that is first 
associated with the message at, or by, switch 1 . Switch 2 in turn associates messages labeled 
Uz as bound for switch 3 and re-labels them as L 23 . Re-labeling messages (e.g. re-labeling a 
message received at switch 2 on L, 2 , as the same message that is output from switch 2 but on 
L 23 and which is received at switch 3, to be re-labeled by switch 3 and output again as L 34 ) is 
known as "label binding." Two or more LSRs, (network switch elements) which use a label 
distribution protocol to exchange label binding information are known as "label distribution 
peers" with respect to the binding information they exchange. 

The label distribution protocol also encompasses any negotiations in which two, label 
distribution peers, need to engage in order to learn of each other's MPLS capabilities. This 
label distribution protocol is referred to as path establishment signaling. MPLS defines two 
methods for label distribution. These two methods are: Label Distribution Protocol (LDP/CR- 
LDP) and ReSerVation Protocol (RSVP). 

Both LDP/CR-LDP and RSVP allow a path to be setup loosely (wherein each node 
determines it's next hop) or explicitly (wherein each node has been given it's next hop). 
These two protocols can be extended, as disclosed herein and by equivalents thereof, to 
provide a novel mechanism by which protection path establishment can be signaled and 
created. Accordingly, a "Protection" field can be defined, and added as an extension to the 
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existing label request messages in LDP/GR-LDP, and path message in RSVP protocols. The 
destination or end point node in the MPLS network participates in setting up a recovery path 
as a merging network switch element. The destination or end point node learns, during a 
signaling or working/protection path configuration process, which working and protection 
5 paths are merged to the same outgoing network switch element. 

Hosts and routers that support both RSVP and Multi-Protocol Label Switching can 
associate labels with RSVP flows. When MPLS and RSVP are combined, the definition of a 
flow can be made more flexible. Once a label switched path (LSP) is established, the traffic 
through the path is defined by the label applied at the ingress node of the LSP (label switched 

1 0 path). The mapping of a label to traffic can be accomplished using a number of different 
criteria. The set of packets that are assigned the same label value by a specific node are said 
to belong to the same forwarding equivalence class (FEC) and effectively define the "RSVP 
flow." When traffic is mapped onto a label-switched path in this way, we call the LSP an 
"LSP Tunnel". When labels are associated with traffic flows, it becomes possible for a router 

1 5 to identify the appropriate reservation state for a packet based on the packet's label value. 

A Path message travels from a sender to receivers) along the same path(s) used by 
the data packets. The IP source address of a Path message must be an address of the sender it 
describes, while the destination address must be the DestAddress for the session. These 
addresses assure that the message will be correctly routed through a non-RSVP cloud. 

20 The format of an exemplary RSVP message with the Protection Object extension is: 



<Path Message> ::= <Common Header> [ <INTEGRITY> ] 
<SESSION> <RSVP_HOP> 
25 [ <TIME_VALUES> ] 

[ <EXPLICIT_ROUTE> ] 

[ <PROTECTION> ] /* The new message field. */ 
<LABEL_REQUEST> 
[ <SESSION_ATTRIBUTE> ] 
30 [ <POLICY_DATA> ... ] 

<sender descriptor> 
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Label Distribution Protocol (LDP) is defined for distribution of labels inside one 
MPLS domain. One of the most important services that may be offered using MPLS in 
general, and LDP in particular, is support for constraint-based routing of traffic across the 
routed network. Constraint-based routing offers the opportunity to extend the information 
used to setup paths beyond what is availablefor the routing protocol. For instance, an LSP 
can be setup based on explicit route constraints, QoS constraints, and other constraints. 

Constraint-based routing (CR) is a mechanism used to meet Traffic Engineering. 
These requirements may be met by extending LDP for support of constraint-based routed 

label switched paths (CR-LSPs). 

The Path Vector TLV is used with the Hop Count TLV in Label Request and Label 
Mapping messages to implement the optional LDP loop detection mechanism. Its use in the 
Label Request message records the path of LSRs the request has traversed. Its use in the 
Label Mapping message records the path of LSRs a label advertisement has traversed to setup 
an LSP. 

The format of an exemplary CR-LDP message with the Protection TLV extension is: 

0 12 3 

01234567890123456789012345678901 

+ _ + . + -+-+-+-+-+-+-+-+-+-+^^ 
|0| Label Request (0x0401) | Message Length | 
+ .+.+.+.+-+-+-+-+-+-+-+-+-+-+-+-+-+-+^^ 
| Message ID I 
. + _ + _ + _ + _+.+-+-+-+-+-+.+-+-+-+-+^ .... 
| FEC TLV I 
+_ + . + . + .+-+-+-+-+-+-+-+-+-+-+-+-+-+^ 
| LSPID TLV (CR-LDP, mandatory) | 

+ _ + _+_+.+-+-+.+-+-+-+-+-+-+-+^ 
| ER-TLV (CR-LDP, optional) | 

+ _ + . + .+.+-+-+-+-+-+-+-+-+-+^ 
| Protection TLV (CR-LDP, optional) | 

+ . + . + .+-+-+.+-+-+-+-+-+-+-+-+-+^ 

| Traffic TLV (CR-LDP, optional) | 

+ . + . + . + . + -+-+.+.+.+-+-+-+-+-+-+-+-+-+-+-+- + -+- + - + 

I Pinning TLV (CR-LDP, optional) | 
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+_+.+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- + - + 
| Resource Class TLV (CR-LDP, optional) | 

+ . + . + . + .+_4..+.+.+.+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+ 

| Pre-emption TLV (CR-LDP, optional) | 

5 + . + . + . + . + .+.+.+.+-+.+.+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- + -+- + - + • 

Wherein the "Protection TLV" message field is new. 

The Protection Object (RSVP)/Protection Type Length Value (TLV) (LDP/CR-LDP) 
1 0 establishes the working and a corresponding protection path utilizing the Reservation 

Protocol (RSVP) path message or the Constraint-Based Routing Label Distribution Protocol 
(CR-LDP) Label Request message. The attributes required to establish the Protection Domain 
are: 
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1 Priority: Specifies whether this protection group is a high or low switching priority. 

2 Protection ID: Specifies whether protection is supported. 

3 Protection Type: Specifies whether this establishment is for the Protection, or Working 
Path. 

20 4 Protection Identity: Specifies a unique identifier for the protection traffic. 

5 Node Identity: Specifies whether the node is a switching, merging, or RNT root node. 

6 RNT Type: Specifies whether the RNT is created using Hop-by-hop, MPLS LSP, or 
SONET K1/K2. 

7 Timer Options: Specifies the hold off and notification time requirements. 

25 8 Recovery Option: Specifies whether the recovery is revertive and if the action is Wait, 
Switch Back, or Switchover. 

9 Protection Bandwidth: Specifies whether the bandwidth of the protection path is available 
to carry excess (preemptable) traffic. 



30 



The following table illustrates the structure of an exemplary Protection 
Object/Protection TLV Structure. 
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0 12 3 

01234567890123456789012345678901 

+ . + . + .+.+.+-+.+.+-+.+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- + -+- + - + - 
. 5 |P|D|T| PGID | N1D |RNTT| TO | RO |B| RESVD | 

+. + .+.+.+.+-+-+-+-+-+-+-+-+-+-+-+-+-+-+- + - + - + - + - + - + - + - + - + - + - + "' 

P= Priority 

D= Protection ID 
1 0 T= Protection Type 

PGID= Protection path Identity 

NID=Node Identity 

RNTT= RNT Type 

TOTimer Options 
15 RO=Recovery Option 

B= Protection Bandwidth 

RESVD=Reserved for Future Use 
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Since the switching systems used in thenetwork 100 are unidirectional, and pathway fault 
recovery requires the notification of faults to a protection switch, such as switch no. 1 or switch 
no. 9, responsible for a switchover to a recovery path, a mechanism is provided for the fault 
indication and the fault recovery notification to travel from a point of occurrence of the fault 
back to the protection switch. The ability to propagate a fault notice upstream however is 
25 complicated when two or more data streams merge in a single switch such as the streams from 
switches 9 and 2 merging at switch 3. When two or more data streams merge at a switch, e.g. 
switch 9, a fault anywhere downstream from switch 9 will require that a fault notice be sent to 
multiple source switches, i.e. switches 9 and 2. The fault indication and recovery notification 
should be able to travel along a reverse path of the working paths to all the protection switch 
30 elements that might be affected by the fault. The path is provided by the reverse notification tree. 

The MPLS protection switch message sequence begins with the establishment 
of the particular working paths and protection paths through the network. The establishment 
of the working path and protection path is accomplished by the transmission of a Protection 
Switch Domain (PSD) initialization message 21 0 from a switch 202 to switches 204, 206 and 
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208. A PSD confirmation message 212 is propagated from the downstream switch 208 

upstream to switch 202. 

The reverse notification path, also referred to above as the Reverse Notification Tree 
or RNT, is established by the downstream switch, 208, sending an RNT initialization 
message 2 14, upstream to switches 206, 204 and 202. Confirmation of the RNT setup is 
accomplished by the RNT Confirmation message 216 that originates from switch 202. 

Upon the establishment of the working and protection paths, and the reverse 
notification tree, data 21 8 can be sent through the network. 

Two "aliveness" messages 220 and 222, which provide notification of the working 
path status, are shown in Figure 2 to depict the fact that the aliveness message described 
above can be sent periodically, regardless of whether downstream data 218 was sent. As 
shown further, downstream data transmissions, such as transmissions 224, 226 and 228 are 
not conditioned upon receipt of an aliveness message in any fixed way. An aliveness message 
230 sent upstream is then followed by yet another data transmission 232. 

Figure 2 shows that the sequence of aliveness messages and data transmissions do not 
need to follow any sort of predetermined or fixed order. For network reliability purposes, the 
aliveness messages are preferably sent periodically, so that their absence can be detected if 
they do not arrive on time. Alternate embodiments include sending liveness messages 
aperiodically. 

Those skilled in the art will recognize that re-routing data on a either the failure of a 
link or a switch in a network such as that depicted in Figure 1 need not be performed by a 
protection switch. In the event that switch 4 fails for example switch no. 3 might reroute data 
from switch 2 that is destined for switch 7, through another protection switch element 9, 
identified by reference numeral 1 16. Switch 9 might then reroute data from switch 2 that is 
addressed to switch 7 over a protection path designed as P 9 ,io and P 10 , 7 through switch 10, 
identified as reference numeral 118. 

In the preferred embodiment, the media over which data message are carried might be 
twisted copper wires, coax cable, fiber optic cable or even a radio frequency data link. As set 
forth above, each of the switching systems might accommodate a variety of packetized data 
messages including but not limited to Ethernet, internet protocol, ATM, frame relay or other 
types of transmission switching systems. 

By continuously sending an upstream message indicating that downstream traffic 
arrives at its destination, recovery time required to recover from the fault of a media link or a 
switching system can be minimized. If the switch status message used to indicate a 



19 



PCT/USOO/29051 

WO 01/29682 

functionality of a switch or a link is sent promptly enough, and to the appropriate node in a 
mesh network such as that shown in Figure 1, the time required to reroute data messages 
between first and second endpoint switches over an alternate data path can be minimized. In 
the preferred embodiment, the alternate or so called protection path is preferably set up in 
advance and maintained in a stand by mode such that it is immediately available when 
required by the protection switch that will reroute data over the protection path. 
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aim: 

In a multi-protocol label switching system (MPLS) data network comprised of a 
plurality of data switches that are interconnected to form a plurality of data paths 
from a source node to a destination node through a first set of data switches, a 
method of establishing a protection path from said source switch to said 
destination switch through a second set of switches, said method comprised of the 
steps of: 

a. sending a first predetermined control message, over a first data path from said 
first switch to a second switch, said first predetermined message establishing 
at least a working path through said network between said first and second 
switches. 

b. sending a second predetermined control message, over a second data path 
from said first switch to a second switch, said second predetermined message 
establishing at least a protection path through said network between said first 
and second switches. 

c. Associating said first working path to said protection path to enable 
protection switching. 

The method of claim 1 wherein said step of sending at least a first predetermined 
message is comprised of the step of adding a protection messaging field to a label 
distribution protocol (LDP) message, said protection messaging field carrying 
protection pathway information between MPLS network switch elements. 

The method of claim 1 wherein said step of sending at least a first predetermined 
message is comprised of the step of adding a protection messaging field in an 
MPLS reservation protocol message (RSVP), said protection field carrying 
protection pathway information between MPLS network switch elements. 

The method of claim 1 wherein said step of sending at least a first predetermined 
message, over a first data path from said first switch to a second switch, said first 
predetermined message establishing at least a working path through said network 
between said first and second switches includes the step of: 
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a. 



identifying at least one data switch of said MPLS network as a switch element 
by the contents of at least one control field in a message field of an MPLS 



message; 

b. sending said at least one control field to at least one data switch of said MPLS 
5 network. 

5. The method of claim 1 wherein said step of sending at least a first predetermined 
message, over a first data path from said first switch to a second switch, said first 
predetermined message establishing at least a protection path through said 
network between said first and second switches includes the step of: 
10 a. identifying at least one data switch of said MPLS network as a protection 

switch element by the contents of at least one control field in a message field 
of an MPLS message; 
b. sending said at least one control field to at least one data switch of said MPLS 

network. 

15 6. The method of claim 1 wherein said step of label binding said first predetermined 
message from said second switch to a third switch. 

7. The method of claim 1 wherein said first data path is set up loosely. 

8. The method of claim 1 wherein said first data path is set up explicitly. 



9. The method of claim 1 further including the step of mapping labels to data routed 
along said first data path according to predetermined criteria that includes the 
quality of service to be granted said data. 

10. In a multi-protocol label switching system (MPLS) data network comprised of a 
plurality of data switches that are interconnected to form a plurality of data paths 
from a source node to a destination node through a first set of data switches, a 
method of establishing a working path from said source switch to said destination 
switch through said first set of switches, said method comprised of the steps of: 

a. sending at least a first predetermined control message, over a first control path 
from said first switch to a second switch, said first predetermined control 
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message establishing at least a working path through said network between 
said first and second switches over which data is to be sent from said source 
switch to said destination switch. 

1 1 . The method of claim 10 wherein said step of sending at least a first predetermined 
5 control message is comprised of the step of adding a protection messaging field to 

a label distribution protocol (LDP) message, said protection messaging field 
carrying protection pathway information between MPLS network switch 
elements. 

12. The method of claim 1 0 wherein said step of sending at least a first predetermined 
1 o control message is comprised of the step of adding a protection messaging field in 

an MPLS reservation protocol message (RSVP), said protection field carrying 
protection pathway information between MPLS network switch elements. 

13. The method of claim 1 0 wherein said step of sending at least a first predetermined 
control message, over a first data path from said first switch to a second switch, 

1 5 said first predetermined control message establishing at least a protection path 

through said network between said first and second switches includes the step of: 
a. identifying at least one data switch of said MPLS network as a protection 

switch element by the contents of at least one data field in a message field of 

an MPLS message; 

20 b. sending said at least one data field to at least one data switch of said MPLS 

network. 

14. The method of claim 1 0 wherein said first data path is set up loosely. 

1 5. The method of claim 1 0 wherein said first data path is set up explicitly. 

16. The method of claim 10 further including the step of mapping labels to data routed 
25 along said first control path according to predetermined criteria that includes the 

quality of service to be granted said data. 
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